# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2000-035985

(43) Date of publication of application: 02.02.2000

(51)Int.Cl.

G06F 17/50 G01R 31/28 H01L 21/82

(21)Application number: 11-110770

19.04.1999

(71)Applicant: DENSO CORP

(72)Inventor: KATO KOJI

**UESUGI HIROSHI** 

(30)Priority

(22)Date of filing:

Priority number: 10132206

Priority date: 14.05.1998

Priority country: JP

## (54) LOGICAL SIMULATION METHOD AND DEVICE

(57)Abstract:

PROBLEM TO BE SOLVED: To provide logical simulation method and device capable of obtaining accurate power consumption and delay time reflecting the influence of self heat generation. SOLUTION: For respective gates which are the constituting elements of a logic circuit to be simulated, gate power consumption (PG) and gate delay time (Tg) are calculated based on a function defined with the self heat generation TH of the gate as a parameter. The entire power consumption Ph and entire delay time Th of the entire circuit are calculated based on the calculated values PG and Tg and a heat generation parameter THp obtained by averaging the self heat generation TH obtained from the gate power consumption PG for respective blocks composed of one or plural gates. Until the deviations of the respective calculated values Ph, Th and THp in the processing of a previous time and the processing of this time all become within an allowable range, the newly calculated heat generation parameter THp is fed back as the self heat generation TH and the above-mentioned processing is repeatedly executed.





## **LEGAL STATUS**

[Date of request for examination]

17.05.2005

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

# (19)日本国特許庁 (JP)

# (12) 公開特許公報(A)

(11)特許出顧公開番号 特開2000-35985 (P2000-35985A)

(43)公開日 平成12年2月2日(2000.2.2)

| (51) Int.Cl.7 | 識別記号  | F I  |               | テーマコート <sup>*</sup> (参考) |
|---------------|-------|------|---------------|--------------------------|
| G06F          | 17/50 | G06F | 15/60 668E    |                          |
| G01R          | 31/28 | G01R | . 31/28 F     |                          |
| H01L          | 21/82 | G06F | 15/60 6 6 6 T | •                        |
|               |       | H01L | . 21/82 C     |                          |

#### 審査請求 未請求 請求項の数14 OL (全 13 頁)

|             |                       |                                                 | MINN HAVEN MIT OL (I TO M) |
|-------------|-----------------------|-------------------------------------------------|----------------------------|
| (21)出願番号    | <b>特顧平</b> 11-110770  | (71)出職人                                         | 000004260                  |
|             |                       |                                                 | 株式会社デンソー                   |
| (22)出顧日     | 平成11年4月19日(1999.4.19) |                                                 | 愛知県刈谷市昭和町1丁目1番地            |
|             |                       | (72)発明者                                         | 加藤耕治                       |
| (31)優先権主張番号 | <b>特膜平</b> 10-132206  |                                                 | 爱知県刈谷市昭和町1丁目1番地 株式会        |
| (32)優先日     | 平成10年5月14日(1998.5.14) |                                                 | 社デンソー内                     |
| (33)優先権主張国  | 日本 (JP)               | (72)発明者                                         | 上杉 浩                       |
|             |                       |                                                 | 爱知果刈谷市昭和町1丁目1番地 株式会        |
|             |                       |                                                 | 社デンソー内                     |
|             |                       | (74)代理人                                         |                            |
|             |                       | (, 2, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | <del>弁理士</del> 足立 勉        |
|             |                       |                                                 |                            |
|             |                       |                                                 |                            |
|             |                       | 1                                               |                            |

# (54) 【発明の名称】 論理シミュレーション方法及び装置

#### (57) 【要約】

【課題】 自己発熱の影響を反映させた精度のよい消費 電力や遅延時間を求めることが可能な論理シュミレーション方法及び装置を提供する。

【解決手段】 シュミレーションすべき論理回路の構成 要素であるゲート毎に、ゲート消費電力PG及びゲート 遅延時間Tgを、ゲートの自己発熱量THをパラメータ として定義された関数に基づいて算出し(S110, S12 0)、この算出値PG, Tgに基づいて回路全体の全消費電力Ph及び全遅延時間Thを算出するとともに、ゲート消費電力PGから求めた自己発熱量THを1又は複数ゲートからなるブロック毎に平均してなる発熱量パラメータTHpを算出し(S130~S160)、前回の処理と今回の処理とで各算出値Ph, Th, THpの偏差が、いずれも許容範囲以内となるまでの間、新たに算出された発熱量パラメータTHpを自己発熱量THとして帰還して、上述の処理を繰り返し実行する。



#### 【特許請求の範囲】

【請求項1】 論理回路を構成する各論理素子の種類や各論理素子間の接続関係を規定するネットリストと、前記論理回路へのテスト入力を規定するテストベクターとに基づいて、前記論理回路の動作を模擬する論理シミュレーション方法において、

前記ネットリスト及びテストベクターに加え、前記論理素子の種類毎に発熱量と遅延時間との関係、及び前記発熱量と単位動作当たりの消費電力との関係を規定するライブラリを用い、各論理素子の発熱量を指定するために設定された発熱量パラメータに基づいて、前記論理回路を構成する各論理素子毎の遅延時間及び消費電力を算出する第1の手順と、

該第1の手順にて算出された各論理素子毎の遅延時間及び消費電力に基づいて、前記論理回路全体としての遅延時間及び消費電力を算出する第2の手順と、

前記第1の手順にて算出された各論理素子毎の消費電力に基づいて各論理素子毎の発熱量を算出し、該算出値に基づいて前記発熱量パラメータを設定することにより、予め設定された収束条件が満たされるまでの間、前記第 20 1及び第2の手順を繰り返し実行させる第3の手順と、を備えることを特徴とする論理シミュレーション方法。

【請求項2】 前記第1の手順は、前記ネットリスト、テストベクター及びライブラリに加え、前記各論理素子間を接続する配線の配線容量を規定する配線情報を用い、前記発熱量パラメータに基づいて、前記論理回路を構成する各論理素子毎の遅延時間及び消費電力を算出することを特徴とする請求項1記載の論理シュミレーション方法。

【請求項3】 論理回路の動作を模擬する論理シミュレーション方法において、論理回路を構成する各論理素子の種類や各論理素子間の接続関係を規定するネットリストと、前記各論理素子間を接続する各配線毎に、該配線により伝達される論理の遷移回数を規定する状態遷移情報と、前記論理素子の種類毎に発熱量と遅延時間との関係、及び前記発熱量と単位動作当たりの消費電力との関係を規定するライブラリとを用い、各論理素子の発熱量を指定するために設定された発熱量パラメータに基づいて、前記論理回路を構成する各論理素子毎の消費電力を算出する第1の手順と、

該第1の手順にて算出された各論理素子毎の消費電力に 基づいて、前記論理回路全体としての消費電力を算出す る第2の手順と、

前記第1の手順にて算出された各論理素子毎の消費電力に基づいて各論理素子毎の発熱量を算出し、該算出値に基づいて前記発熱量パラメータを設定することにより、予め設定された収束条件が満たされるまでの間、前記第1及び第2の手順を繰り返し実行させる第3の手順と、を備えることを特徴とする論理シミュレーション方法。

【請求項4】 前記第1の手順は、前記ネットリスト及 50

びライブラリに加え、前記各論理素子間を接続する配線の配線容量を規定する配線情報を用い、前記発熱量パラ

メータに基づいて、前記論理回路を構成する各論理素子 毎の消費電力を算出することを特徴とする請求項3記載 の論理シュミレーション方法。

2

【請求項5】 論理回路を構成する各論理素子の種類や各論理素子間の接続関係を規定するネットリストと、前記論理回路へのテスト入力を規定するテストベクターとに基づいて、前記論理回路の動作を模擬する論理シミュレーション装置において、

前記ネットリスト及びテストベクターに加え、前記論理素子の種類毎に発熱量と遅延時間との関係、及び前記発熱量と単位動作当たりの消費電力との関係を規定するライブラリを用い、各論理素子の発熱量を指定するために設定された発熱量パラメータに基づいて、前記論理回路を構成する各論理素子毎の遅延時間及び消費電力を算出する素子情報算出手段と、

該素子情報算出手段での算出結果に基づいて、前記論理 回路全体としての遅延時間及び消費電力を算出する全体 情報算出手段と、

前記素子情報算出手段にて算出された各論理素子毎の消 費電力に基づいて各論理素子毎の発熱量を算出する発熱 量算出手段と、

該発熱量算出手段での算出結果に基づいて前記発熱量パラメータを設定することにより、予め設定された収束条件が満たされるまでの間、前記素子情報算出手段を繰り返し起動する起動制御手段と、

を備えることを特徴とする論理シミュレーション装置。

【請求項6】 前記素子情報算出手段は、前記ネットリスト、テストベクター及びライブラリに加え、前記各論理素子間を接続する配線の配線容量を規定する配線情報を用い、前記発熱量パラメータに基づいて、前記論理回路を構成する各論理素子毎の遅延時間及び消費電力を算出することを特徴とする請求項5記載の論理シュミレーション装置。

【請求項7】 前記起動制御手段は、前記全体情報算出手段にて算出される前記論理回路全体の遅延時間又は消費電力、或いは当該起動制御手段にて算出される前記発熱量パラメータのうち、少なくともいずれか一つを判定パラメータとし、該判定パラメータについて、前回の算出結果からの偏差が予め設定された許容範囲内にある場合に前記収束条件を満たしたものとすることを特徴とする請求項5,6何れか記載の論理シミュレーション装置。

【請求項8】 前記起動制御手段は、予め設定された再起動回数だけ前記素子情報算出手段を再起動した場合に前記収束条件を満たしたものとすることを特徴とする請求項5,6何れか記載の論理シミュレーション装置。

【請求項9】 前記起動制御手段は、前記論理回路を1 又は複数の論理素子毎に分割してなるブロック毎に、前 記発熱量算出手段にて算出された発熱量の平均値を求め、該発熱量の平均値を前記発熱量パラメータとして設定することを特徴とする請求項5ないし請求項8のいずれかに記載の論理シミュレーション装置。

【請求項10】 論理回路の動作を模擬する論理シミュレーションにおいて、論理回路を構成する各論理素子の種類や各論理素子間の接続関係を規定するネットリストと、前記各論理素子間を接続する各配線毎に、該配線により伝達される論理の遷移回数を規定する状態遷移情報と、前記論理素子の種類毎に発熱量と遅延時間と、及び前記発熱量と単位動作当たりの消費電力との関係を規定するライブラリとを用い、各論理素子の発熱量を指定するために設定された発熱量パラメータに基づいて、前記論理回路を構成する各論理素子毎の消費電力を算出する素子情報算出手段と、

該素子情報算出手段での算出結果に基づいて、前記論理 回路全体としての消費電力を算出する全体情報算出手段 と、

前記素子情報算出手段にて算出された各論理素子毎の消費電力に基づいて各論理素子毎の発熱量を算出する発熱 20 量簋出手段と.

該発熱量算出手段での算出結果に基づいて前記発熱量パラメータを設定することにより、予め設定された収束条件が満たされるまでの間、前記素子情報算出手段を繰り返し起動する起動制御手段と、

を備えることを特徴とする論理シミュレーション装置。 【請求項11】 前記素子情報算出手段は、前記ネット リスト、状態遷移情報及びライブラリに加え、前記各論 理素子間を接続する配線の配線容量を規定する配線情報 を用い、前記発熱量パラメータに基づいて、前記論理回 路を構成する各論理素子毎の消費電力を算出することを 特徴とする請求項10記載の論理シュミレーション装

【請求項12】 前記起動制御手段は、前記全体情報算出手段にて算出される前記論理回路全体の消費電力、或いは当該起動制御手段にて算出される前記発熱量パラメータのうち、少なくともいずれか一つを判定パラメータとし、該判定パラメータについて、前回の算出結果からの偏差が予め設定された許容範囲内にある場合に前記収束条件を満たしたものとすることを特徴とする請求項10、11何れかに記載の論理シミュレーション装置。

【請求項13】 前記起動制御手段は、予め設定された 再起動回数だけ前記素子情報算出手段を再起動した場合 に前記収束条件を満たしたものとすることを特徴とする 請求項10,11何れか記載の論理シミュレーション装 置

【請求項14】 前記起動制御手段は、前記論理回路を 1又は複数の論理素子毎に分割してなるブロック毎に、 前記発熱量算出手段にて算出された発熱量の平均値を求 め、該発熱量の平均値を前記発熱量パラメータとして設 50 定することを特徴とする請求項10ないし請求項13の いずれかに記載の論理シミュレーション装置。

#### 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、論理回路の動作を 模擬する論理シミュレーション方法及び装置に関する。 【0002】

【従来の技術】従来より、論理回路の動作を模擬(シミュレーション)する方法として、回路を構成するトランジスタ等の各素子の特性を規定する30~200ものパラメータ(例えば、移動度、膜厚等)を、シミュレーションすべき対象回路の条件に応じて設定し、これらパラメータ間の相互関係等を規定する方程式を解くことにより、微少時間毎に信号レベルを逐次算出して信号波形を求める、いわゆるアナログシミュレーションや、このアナログシミュレーションのように精密な波形を再現するのではなく、各論理素子(ゲート)での遅延時間を考慮して0、1レベルで動作を再現する、いわゆる論理シミュレーションが知られている。

【0003】このうち、前者(アナログシミュレーション)では、信号波形を精密に求めることができるが、膨大な計算量が必要なため、比較的小規模な回路でのシミュレーションに適しており、一方、後者(論理シミュレーション)では、前者と比較して、格段に少ない計算量で結果を求めることができるため、集積回路等の大規模な回路(実用上、数百万ゲート程度まで)でのシミュレーションに適している。

【0004】なお、論理回路を構成する各ゲートでは、電流が流れると自己発熱し、この自己発熱がゲートの特性を規定する各種パラメータを変化させ、ゲートを流れる電流値や信号の遅延時間等に影響が表れることが知られているが、従来は、この自己発熱は十分に小さく、これを無視してシミュレーションを行っても特に問題となるようなことはなかった。

#### [0005]

【発明が解決しようとする課題】ところが、近年、SOI (Silicon On Insulator) 形半導体デバイスの登場や、論理回路の動作周波数の著しい向上のために、動作時の自己発熱による論理回路の各種特性への影響が増大する傾向にあり、この自己発熱の影響を無視できないようになりつつある。

【0006】即ち、SOIデバイスでは、ゲートを構成するトランジスタ等の各素子は、それぞれがシリコン絶縁基板にて包囲されており熱伝導度が低いため、電流が流れると、その電流に伴う発熱を十分に放熱できずに自己発熱量が大きくなってしまい、また、論理回路では、通常、信号の反転時に電力を消費するが、動作周波数が向上すると、単位時間当たりの信号の反転回数、即ち消費電力が増大し、自己発熱量が大きくなってしまうのである。

【0007】また、論理回路の性能を最大限に引き出して高速動作させるためには、論理回路の動作限界を知る必要があり、そのためには、各ゲート毎及び論理回路全体としての遅延時間(動作周波数)や消費電力を精度よく計算しなければならない。これに対して、例えば、特開平5-226368号公報に開示されているように、自己発熱による温度変化を算出し、素子の特性を規定するパラメータの一つである移動度を、この温度変化に応じて変化させて、各種計算を行うことにより、自己発熱の影響を反映させたアナログシミュレーションを行うものが提案されている。ところが、現状では、このような自己発熱の影響を反映させた論理シミュレーションは行われていない。

【0008】従って、自己発熱が大きい場合に精度よくシミュレーションを行うには、アナログシミュレーションを用いざるをえないが、上述したように、実用上、あまり大規模な論理回路に適用することはできず、自己発熱の影響を反映させた論理シミュレーションへの要求が高まっている。

【0009】そこで本発明は、上記問題点を解決するた 20 めに、自己発熱の影響を反映させた精度のよい消費電力 や遅延時間を求めることが可能な論理シミュレーション 方法及び装置を提供することを目的とする。

#### [0010]

【課題を解決するための手段】上記目的を達成するため になされた発明である請求項1に記載の論理シミュレー ション方法では、第1の手順にて、ネットリスト及びテ ストベクターに加え、論理素子の種類毎に発熱量と遅延 時間や単位動作当たりの消費電力との関係を規定するラ イブラリを用い、各論理素子の発熱量を指定するために 設定された発熱量パラメータに基づいて、論理回路を構 成する各論理素子毎の遅延時間及び消費電力を算出し、 第2の手順にて、この第1の手順にて算出された各論理 素子毎の遅延時間及び消費電力に基づいて、前記論理回 路全体としての遅延時間及び消費電力を算出し、更に、 第3の手順にて、第1の手順にて算出された各論理素子 毎の消費電力に基づいて各論理素子毎の発熱量を算出 し、該算出値に基づいて第1の手順にて用いる発熱量パ ラメータを設定することにより、予め設定された収束条 件が満たされるまでの間、第1及び第2の手順を繰り返 40 し実行させる。

【0011】なお、単位動作とは、信号の立ち上がりや、立ち下がり等、電力消費を伴う最小単位の動作のことである。即ち、シミュレーションの開始時には、各論理素子の発熱量がどの程度になるのか正確に知ることはできないため、発熱量パラメータとして適当に仮定して初期値を設定し、第1~3の手順を実行する。

【0012】その結果、各論理素子及び論理回路全体の 消費電力及び遅延時間が算出され、また各論理素子の消 費電力に従って、各論理素子の発熱量、ひいては発熱量 50

パラメータが算出される。このとき、初期値として仮定 した発熱量パラメータが妥当な値であれば、仮定値と算 出値とでほぼ同じ大きさとなる。

【0013】しかし、当初設定した発熱量パラメータの 値が小さすぎれば、この設定に基づいて算出される消費 電力は実際より大きめ、遅延時間は実際より小さめにな り、逆に発熱量パラメータの値が大きすぎれば、消費電 力は実際より小さめ、遅延時間は実際より大きめにな る。

【0014】従って、算出された消費電力に基づいて求めた発熱量、ひいては発熱量パラメータを、新たに第1の手順を行う際の設定値として、処理を繰り返すことにより、前回の処理にて算出された消費電力、遅延時間、発熱量(発熱量パラメータ)と、この前回の処理にて算出された発熱量パラメータに基づき今回の処理にて算出された消費電力、遅延時間、発熱量(発熱量パラメータ)との偏差が収束する方向に算出値は変化する。

【0015】このため、これらの偏差が十分に収束するように、収束条件を設定して、収束条件を満たすまで、上記手順による処理を繰り返し実行することにより、各論理素子の自己発熱による影響を反映した消費電力や遅延時間を精度よく求めることができる。

【0016】特に遅延時間からは、論理回路の高速動作の限界を精度よく求めることができるため、論理回路の性能を最大限に引き出すことができる。次に、請求項2記載の論理シュミレーションでは、実際の論理回路では、論理素子を結ぶ配線に配線容量があるので、第1の手順において、その配線容量を規定する配線情報を用い、論理回路を構成する各論理素子毎の遅延時間及び消費電力を算出している。

【0017】そのため、この請求項2記載の論理シュミレーション方法を用いると、請求項1記載の論理シュミレーション方法に比べ、より実際に即した各論理素子の消費電力や遅延時間を精度よく求めることができる。ところで、上述した論理シュミレーション方法では、第1の手順においてテストベクターを使って各論理素子の消費電力を算出しているが、この消費電力の算出は、通常、テストベクタを用いて個々のゲートの動作を再現することによって各論理素子の遷移回数が分かるので、その遷移回数に論理素子の1回の動作あたりに要する消費電力を乗じて算出している。

【0018】尚、ここで遷移回数とは、上述した単位動作が行われる回数である。そこで、請求項3記載の論理シュミレーション方法では、第1の手順において、テストベクターに代えて、各論理素子間を接続する各配線毎に、該配線により伝達される論理の遷移回数を規定する状態遷移情報を用い、これとネットリスト及びライブラリを使って、各論理素子の消費電力を算出し、論理回路全体の消費電力を算出している。

【0019】このようにすると、予め入力された状態遷移情報を用いることでテストベクタを用いて個々のゲートの動作を再現することなく各論理素子の消費電力を短時間に簡易的に算出することができる。ここで、論理回路の設計を行うには幾つかの段階があって、比較的初期のアイディア段階では、通常論理回路の動作限界を精密に知ることは求められない。しかし、アイディアとして提示された論理回路が、設計の最終段階に至って初めて動作しないことが分かるといったことが往々にして生じ、設計に要する時間の無駄が生ずる場合があるので、アイディア段階で論理回路の動作限界をある程度考慮した設計をすることが求められる。

【0020】そのため、そのアイディア段階においても、テストベクターを用いて個々のゲートの動作を再現した後消費電力等を算出してもよいが、アイディア段階で取り上げられる論理回路の数が設計の最終段階で取り上げられるものの数に比較してかなり多く、また単に思いついた論理回路等も存在して、それらの論理回路全てについてテストベクタを用いて個々のゲートの動作を再現するシュミレーションを行うことはあまり考えられないので、請求項1、2記載の論理シュミレーション方法は、アイディア段階での論理回路の設計には不向きな場合がある。

【0021】一方、実際の論理回路の設計においては、通常各論理素子の動作を予想しながら行うことが多い。従って、この請求項3記載の論理シュミレーション方法を用いれば、例えば、論理回路の設計において、動作限界を知るためのパラメータである消費電力を簡易的に求めることができ、アイディア段階で動作限界を越える論理回路が選別され排除されるので、設計の最終段階に至って初めて論理回路が動作しないことが分かるといったことが少なくなり、論理回路の設計を効率よく進めることができる。ただし、この請求項3記載の論理シュミレーション方法では、正確な遷移回数を入力すれば精密に消費電力を算出できるので、アイディア段階ばかりでなく設計のどの段階でも用いることができることはもちろんである。

【0022】また、請求項3記載の論理シュミレーション方法を用いれば、テストベクターを準備できない、例えば、簡易的に現状の論理回路全体で消費される全消費電力を求めたい用途においても、適当な遷移回数を記憶したファイルを準備しさえすれば、算出することができる。

【0023】また、請求項4記載の倫理シュミレーション方法のように、第1の手順において、各論理素子間を接続する配線の配線容量を規定する配線情報を用い、各論理素子の発熱量を指定するために設定された発熱量パラメータに基づいて、論理回路を構成する各論理素子毎の消費電力を算出するようにしてもよい。

【0024】このようにすれば、請求項3記載の論理シ ユミレーションと比較して、より実際の論理回路に即し た消費電力の正確な演算を行うことができる。次に、請 求項5に記載の論理シミュレーション装置では、素子情 報算出手段が、ネットリスト及びテストベクターに加 え、論理素子の種類毎に発熱量と遅延時間との関係や、 その発熱量と単位動作当たりの消費電力との関係を規定 するライブラリを用い、各論理素子の発熱量を指定する ために設定された発熱量パラメータに基づいて、論理回 路を構成する各論理素子毎の遅延時間及び消費電力を算 出し、全体情報算出手段が、素子情報算出手段での算出 結果に基づいて、論理回路全体としての遅延時間及び消 費電力を算出し、発熱量算出手段が、素子情報算出手段 にて算出された各論理素子毎の消費電力に基づいて各論 理素子毎の発熱量を算出し、そして、起動制御手段が、 発熱量算出手段での算出結果に基づいて発熱量パラメー タを設定することにより、予め設定された収束条件が満 たされるまでの間、素子情報算出手段を繰り返し起動す

【0025】この請求項5に記載の装置は、請求項1に記載の方法を実現するものであり、即ち、素子情報算出手段が第1の手順、全体情報算出手段が第2の手順、発熱量算出手段及び起動制御手段が第3の手順を実現している。従って、本発明の論理シミュレーション装置を用いれば、請求項1に記載の発明と全く同様の作用効果が得られる。

【0026】次に、請求項6記載の論理シュミレーション装置では、素子情報算出手段が、ネットリスト、テストベクター及びライブラリに加え、各論理素子間を接続する配線の配線容量を規定する配線情報を用い、発熱量パラメータに基づいて、論理回路を構成する各論理素子毎の遅延時間及び消費電力を算出している。

【0027】この請求項6に記載の装置は、請求項2に記載の方法を実現するものである。従って、本発明の論理シミュレーション装置を用いれば、請求項2に記載の発明と全く同様の作用効果が得られる。ところで、起動制御手段にて用いる収束条件については、例えば、請求項7に記載のように、全体情報算出手段にて算出される論理回路全体の遅延時間又は消費電力、或いは当該起動制御手段にて算出される発熱量パラメータのうち、少なくともいずれか一つを判定パラメータとし、この判定パラメータについて、前回の算出結果からの偏差が予め設定された許容範囲内にある場合に収束条件を満たしたものとすることができる。

【0028】この場合、偏差と比較する許容範囲の大きさを適宜設定することにより、判定パラメータとして用いた算出値(遅延時間、消費電力、発熱量パラメータ)を、所望の誤差内で求めることができる。また、本発明では、収束判定を、個々の論理素子毎ではなく、論理回路全体として行っているので処理量が少なく、従って、

シミュレーション結果を比較的短時間で得ることができる。

【0029】なお、判定パラメータとしては、遅延時間、消費電力、発熱量パラメータのうち、いずれか一つであってもよいし、いずれか二つであってもよいし、三つ全部であってもよい。また、複数の判定パラメータを設定した場合には、そのいずれもが、それぞれの許容範囲内にある場合にのみ収束条件を満たしたとしてもよいし、いずれか一つでも許容範囲内にあれば、収束条件を満たしたとしてもよい。そして、これら判定パラメータの数や許容範囲の大きさは、必要とされる精度や、装置の処理能力、許容処理時間等に応じて適宜設定すればよい。

【0030】ところで、起動制御手段にて用いる収束条件としては、請求項7に示したもの以外に、例えば、ある再起動回数以上処理を繰り返すと、判定パラメータの偏差が許容範囲内に確実に収束することがわかっていれば、請求項8に記載のように、予め設定された再起動回数だけ素子情報算出手段を再起動した場合に収束条件を満たしたものとみなすようにしてもよい。

【0031】この場合、上述のような判定パラメータの偏差を算出し判定する処理を省略することができるため、処理を簡略化することができる。次に、請求項9に記載の論理シミュレーション装置では、起動制御手段は、論理回路を1又は複数の論理素子毎に分割してなるブロック毎に、発熱量算出手段にて算出された発熱量の平均値を求め、この発熱量の平均値を素子情報算出手段にて用いる発熱量パラメータとして設定する。

【0032】つまり、すべてのブロックが、1個の論理素子からなる場合には、発熱量算出手段での算出値が、そのまま発熱量パラメータとなり、複数の論理素子からなるブロックでは、その平均発熱量が、ブロック内の論理素子で共通な発熱量パラメータとなる。

【0033】このように、ブロック毎に発熱量パラメータを求めることにより、ブロック内に同一の論理素子があれば、単位動作当たりの消費電力の算出等を共通に行うことができるため、処理量の削減を図ることができる。次に、請求項10記載の論理シュミレーション装置では、素子情報算出手段が、各論理素子毎の遅延時間及び消費電力を算出するため、各論理素子間を接続する各配線毎に、該配線により伝達される論理の遷移回数を規定する状態遷移情報を用いている点が請求項5の論理シュミレーション装置と異なる。

【0034】この請求項10に記載の装置は、請求項3に記載の方法を実現するものであり、即ち、素子情報算出手段が第1の手順、全体情報算出手段が第2の手順、発熱量算出手段及び起動制御手段が第3の手順を実現している。従って、本発明の論理シミュレーション装置を用いれば、請求項3に記載の発明と全く同様の作用効果が得られる。

【0035】次に、請求項11記載の論理シュミレーション装置では、素子情報算出手段が、ネットリスト、状態遷移情報及びライブラリに加え、各論理素子間を接続する配線の配線容量を規定する配線情報を用い、発熱量パラメータに基づいて、論理回路を構成する各論理素子毎の消費電力を算出している。

【0036】この請求項11に記載の装置は、請求項4に記載の方法を実現するものである。従って、本発明の 論理シミュレーション装置を用いれば、請求項4に記載 の発明と全く同様の作用効果が得られる。

【0037】次に、請求項12記載の論理シュミレーション装置では、起動制御手段が、全体情報算出手段にて算出される論理回路全体の消費電力、或いは起動制御手段にて算出される発熱量パラメータのうち、少なくともいずれか一つを判定パラメータとし、この判定パラメータについて、前回の算出結果からの偏差が予め設定された許容範囲内にある場合に収束条件を満たしたものとしている。また、請求項13記載の論理シュミレーション装置では、起動制御手段は、予め設定された再起動回数だけ素子情報算出手段を再起動した場合に収束条件を満たしたものとしている。また、請求項14記載の論理シュミレーション装置では、起動制御手段は、論理回路を1又は複数の論理素子毎に分割してなるブロック毎に、発熱量算出手段にて算出された発熱量の平均値を求め、該発熱量の平均値を発熱量パラメータとして設定している。

【0038】これら請求項12~14記載の論理シュミレーション装置は、テストベクターに代えて状態遷移情報を用いて論理シュミレーションを実行すること及び、遅延時間を判定パラメータとして用いることができないこと以外は、それぞれ請求項7~9の論理シュミレーション装置(請求項12は請求項7に、請求項13は請求項8に、請求項14は請求項9にそれぞれ対応する)と同様の作用効果を奏するので、その説明を省略する。

## [0039]

【発明の実施の形態】 [第1実施例] 以下に本発明の第 1実施例を図面と共に説明する。図1は、本発明が適用 された論理シミュレーション装置2の全体構成を表すブ ロック図である。

【0040】本実施例の論理シミュレーション装置2は、図1に示すように、フロッピーディスク,ハードディスク,磁気テープ等の記憶装置からなり、シミュレーションすべき論理回路を構成する論理素子(以下、ゲートという)の種類や各ゲート間の接続関係などを規定するネットリストNL、シミュレーションを実行する際の論理回路への入力信号(以下、テスト入力という)を規定するテストベクターVC、ゲートの種類毎に発熱量と遅延時間との関係や、発熱量と単位動作当たりの消費電力との関係を規定するライブラリLBが格納されたデータ記憶部10と、キーボード、マウス、タッチパネル等

の算出を行う際には、各ブロック毎に、ゲート発熱量T

Hとして共通の発熱量パラメータTHpを用いるように されている。

12

【0045】次に、シミュレーション実行部16のCP U16aが実行するシミュレーション処理を、図4に示 すフローチャートに沿って説明する。なお、本処理のプ ログラムは、予めROM16bに記憶されていてもよい し、図示しないフロッピーディスク等の外部記憶装置か らRAM16cにロードするようにしてもよい。

【0046】また、本処理は、入力操作部12を介し て、シミュレーションを開始すべき旨の指令が入力され ると起動され、まずS100では、発熱量パラメータT Hpの初期値の設定を行う。これは、表示部14に、発 熱量パラメータTHpの初期値の入力を促す表示を行 い、入力操作部12を介して値の入力があると、その入 力された値を、発熱量パラメータTHpの初期値として 設定することにより行う。

【0047】なお、発熱量パラメータTHpの初期値 は、外部からの入力によることなく、固定値(例えば 0) を自動的に設定するようにしてもよい。続くS11 0では、設定された発熱量パラメータTHpを用い、ラ イブラリLBにて定義された関数fpに従って、ネット リストNLに定義された論理回路を構成する全ゲートに ついて、個々に単位ゲート消費電力Pgを算出し、更 に、この単位ゲート消費電力PgとテストベクターVC とに基づいて、各ゲート毎に、テストベクターVCの全 期間に渡る消費電力(以下、ゲート消費電力という)P Wを算出する。

【0048】続くS120では、設定された発熱量パラ メータTHpを用い、ライブラリLBに定義された関数 ftに従って、ネットリストNLに定義された論理回路 を構成する全ゲートについて、個々にゲート遅延時間T gを算出する。そして、S130では、先のS110に て各ゲート毎に算出されたゲート消費電力PWを全て積 算することにより論理回路全体としての消費電力(以 下、全消費電力という)Phを算出し、S140では、 先のS120にて各ゲート毎に算出されたゲート遅延時 間Tg、及びネットリストNL、テストベクターVCに 基づいて、各ゲートでの入出力タイミングを逐次計算す ることにより、論理回路全体としての遅延時間(以下、 全遅延時間という)Th、及びテストベクターVCに対 する論理回路からの出力信号を求める。

【0049】続くS150では、先のS110にて算出 されたゲート消費電力PWに基づいて、次の(1)式を 用いて、消費電力PWに応じて生じる自己発熱の大きさ を表すゲート発熱量THを算出する。但し、a, bは、 論理回路が構成される基板等の物性によって決まる定数 である。

[0050]

の入力装置からなり、当該装置2を動作させる各種指令 を入力するための入力操作部12と、LED, LCD, CRT等のディスプレイからなり、入力操作部12を介 した操作の手順や指令に対する処理結果等を表示する表 示部14と、CPU16a, ROM16b, RAM16 c を中心に構成された周知のマイクロコンピュータから なり、データ記憶部10に記憶されたネットリストN L, テストベクターVC, ライブラリLBに基づき、入 力操作部12からの指令に従って、論理回路のシミュレ ーションを行い、その処理結果を表示部14に表示する 等の処理を実行するシミュレーション実行部16とを備 えている。

【0041】ここで、ライブラリLBは、図2に示すよ うに、論理積回路AND, 論理和回路OR, 排他的論理 和回路 XOR…等の各ゲートの種類(図では、2入力否 定論理積回路NAND2, 反転回路INV) 毎に、入力 (A, B) に対して出力(YB) を生成する際の論理式 (領域M1) と、入力端子での入力容量(Ca, C b), 出力端子での駆動能力R, 信号立ち上がり時及び 立ち下がり時等の単位動作当たりの消費電力(以下、単 20 位ゲート消費電力という) Pg, 及び信号の入力レベル が変化してから出力レベルが変化するまでの遅延時間 (以下、ゲート遅延時間という) Tg等、ゲートの特性

を表す各種パラメータ(領域M2)が格納されている。 【0042】そして、駆動能力R,単位ゲート消費電力 Pg、ゲート遅延時間Tgは、いずれもゲートの自己発 熱量(以下、ゲート発熱量という)THをパラメータと する関数 f r (TH), f p (TH), f t (TH)により定 義されている。ここで図3(a)は、ゲート発熱量TH と単位ゲート消費電力Pgとの関係、図3(b)は、ゲ ート発熱量THとゲート遅延時間Tgとの関係を表すグ ラフの一例である。図示されているように、単位ゲート 消費電力Pgは、ゲート発熱量THが増大するほど小さ くなり、一方、ゲート遅延時間Tgは、ゲート発熱量T Hが増大するほど大きくなる。そして、上記関数fp, f tは、予め実験等によって求められたこれらのグラフ を近似するように定義されたものである。

【0043】なお、特にゲート発熱量THと単位ゲート 消費電力Pgとの関係は、自己発熱で温度が上昇する と、接合リーク電流(ドレイン・ソースからバルクに漏 40 れる電流) が増加して消費電力も増大するため、必ずし も図3(a)に示したような右下がりのグラフになると は限らない。

【0044】また、ネットリストNLやテストベクター VCは、この種のシミュレーションに従来より使用され ている周知のものであり、ここではその詳細についての 説明を省略する。但し、ネットリストNLでは、論理回 路を構成する全てのゲートが、1又は複数のゲートから なる複数のブロックに分割されており、ライブラリLB を用いて単位ゲート消費電力Pgやゲート遅延時間Tg 50

#### $TH = a \cdot PW + b$

なお、ゲート発熱量THの算出式は、(1)式に限定されるものではなく、一次関数以外の式で表されていてもよい。また、算出式によらずテーブルを用いてゲート発熱量THを求めてもよい。

【0051】更にS160では、S150にて求めたゲ ート発熱量THに基づき、ブロック毎にその平均値を算 出して、これを発熱量パラメータTHpとして設定す る。そして、S170では、本ステップが本処理の起動 後にはじめて実行されたのであれば、S130, S14 0、S160にて算出された全消費電力Ph, 全遅延時 間Th,発熱量パラメータTHpを前回の算出値として 記憶した後、S110に戻り、また、本処理の起動後、 本ステップが既に1回以上実行されているのであれば、 即ち、前回の算出値が記憶されているのであれば、全消 費電力Ph,全遅延時間Dh,発熱量パラメータTHp のすべてについて、それぞれ、今回の算出値と前回の算 出値との偏差を算出して、そのいずれもが、予め設定さ れた許容範囲内にあるか否かを判断する。そして、否定 判定された場合には、今回の算出値を前回の算出値とし て記憶した後S110に戻り、一方、肯定判定された場 合には、S180に移行し、シミュレーション結果とし て、全消費電力Ph,全遅延時間Th、及びテストベク ターVCに対する出力波形(タイミング)等を、表示部 14に表示した後、本処理を終了する。

【0052】なお、S170では、例えば、予め設定された上限回数だけ連続して否定判定された場合、即ち、上限回数だけ処理を繰り返しても、判定パラメータが収束しなかった場合には、その旨を表示部14に表示して本処理を強制的に終了するようにしてもよい。

【0053】また、S110, S120が第1の手順及び素子情報算出手段に相当し、S130, S140が第2の手順及び全体情報算出手段に相当し、S150~S170が第3の手順に相当し、特にS150, S160が発熱量算出手段、S170が起動制御手段に相当する。

【0054】ここで、図5は、S110~S170の処理を繰り返すことにより、逐次算出される全消費電力Ph(即ち発熱量TH)及び全遅延時間Th(即ち動作周波数)が変化する様子を表す説明図である。即ち、反復回数0の位置に示すように、発熱量パラメータTHpの初期値が、実際の発熱量より小さな値(例えば0)に設定されたとすると(S100)、これに基づいて、反復回数1の位置に示すように、実際より大きめの全消費電力Phと実際より小さめの全遅延時間Thとが算出される(S110~S140)。この全消費電力Phの算出に用いたゲート消費電力PWに基づき、(1)式を用いて、ゲート発熱量THを算出し、ひいては発熱量パラメータTHpが算出される(S150,S160)。そして、この初回の処理では、未だ前回の算出値が記憶され50

(1)

ていないため、収束判定を行うことなく、この発熱量パラメータTHpに基づいて、2回目の処理が行われる。すると、反復回数2の位置に示すように、再度、全消費電力Ph,全遅延時間Th,及び発熱量パラメータTHpが算出され(S110~S160)。この時の前回の算出値との偏差 $\triangle$ P, $\triangle$ T, $\triangle$ THpにより収束判定が行われ、ここでは、偏差 $\triangle$ P, $\triangle$ T, $\triangle$ THpがいずれも許容範囲に収まらないため、3回目以降の処理が行われる。

【0055】その後、S110~S170処理を繰り返すことにより、前回の算出値との偏差が、いずれも許容範囲に納まった、即ち収束条件が満たされたと判定されると(図5では、反復回数5)本処理を終了するのである。以上、説明したように、本実施例の論理シミュレーション装置2においては、設定された発熱量パラメータTHpに基づいてゲート消費電力PG及びゲート遅延時間Tg、ひいては判定パラメータ(全消費電力Ph,全遅延時間Th,発熱量パラメータTHp)を算出し、これら各判定パラメータPh,Th,THpについて、今回の処理の算出値と前回の処理の算出値との偏差が十分に小さく(許容範囲内に)なるまでの間、新たに算出された発熱量パラメータTHpを用いて、上記処理を繰り返すようにされている。

【0056】その結果、本実施例の論理シミュレーション装置によれば、ゲートの自己発熱(発熱量TH)の影響を反映させた全消費電力Phや全遅延時間Thを、収束判定に用いた許容範囲以下の誤差で、精度よく求めることができる。特に組み合わせ回路に限るが、全遅延時間Thからは、論理回路の上限動作周波数、即ち、論理回路の動作速度の限界を知ることができるため、動作速度の点では論理回路の性能を最大限に引き出すことができる。

【0057】また、本実施例では、ブロック毎に発熱量パラメータTHpを求めているので、ブロック内に同一種類のゲートがあれば、単位ゲート消費電力Pgやゲート遅延時間Tgの算出を共通に行うことができ、処理量の削減を図ることができる。なお、発熱量パラメータTHpの算出単位となるブロックは、論理回路全体を1ブロックとしてもよいし、各ゲートを1ブロックとしてもよい。各ゲートを1ブロックとした場合には、S150にて算出されるゲート発熱量THを、そのまま発熱量パラメータTHpとして使用すればよい。

【0058】また、上記実施例では、単位ゲート消費電力Pgやゲート遅延時間Tgの算出を、ライブラリLBに定義された関数fp,ftを用いて行っているが、この関数fp,ftに代えて、これらの関係(図3(a)及び(b)参照)を表すテーブルを用いて行ってもよい。なお、関数を用いた場合、使用する全領域で均一な精度を保つことが困難である場合や、精度を向上させよ

うとすると関数が複雑になって処理量を増大させてしまう場合があるが、テーブルを用いれば、実現すべき関係を表すグラフがどのように複雑であったとしても、全領域に渡って、同じ処理量にて、ほぼ同じ精度で算出することができる。ところで、上記実施例では、S170での収束判定を、全消費電力Ph,全遅延時間Th,発熱量パラメータTHpの全てを判定パラメータとして用い、全ての判定パラメータについて前回の算出値と今回の算出値との偏差が許容範囲内となった場合に収束したと判定しているが、これら三つの判定パラメータのうちいずれか一つ、又はいずれか二つのみが、許容範囲内に入った場合に、収束したと判定してもよい。

【0059】また、判定パラメータとして三つ全てを用 いるのではなく、いずれか一つ、又はいずれか二つのみ を用いるようにしてもよい。そして、特に、全遅延時間 Thのみを判定パラメータとする場合には、図6に示す ように、全消費電力Phを算出するステップ(S27 0)を、処理ループの外に出すことができると共に、収 東判定にて否定判定された(S240-NO)場合にの み、次回の処理に用いる発熱量パラメータTHpを算出 20 するステップ(S250, S260)を実行すればよい ため、処理量を軽減することができる。 なお、図6のフ ローチャートにおいて、S200~S230, S250 ~S280の処理は、S100~S160、S180の 処理を一部並べ変えただけで全く同様の処理を行ってお り、即ちS200~S220がS100~S120, S 230 # S 1 40, S 2 5 0 ~ S 2 6 0 # S 1 5 0 ~ S 160, S270がS130, S280がS180とそ れぞれ全く同様の処理を行っている。

【0060】また、全消費電力Phのみを判定パラメータとする場合には、図6において、全消費電力Phを算出するステップの代わりに、ゲート遅延時間Tg及び全遅延時間Thを算出するステップを、処理ループの外に出せばよい。また更に、発熱量パラメータTHpのみを判定パラメータとする場合には、図7に示すように、全消費電力Ph及び全遅延時間Thを算出する両ステップ(S360、S370)を、処理ループの外に出すことができるため、更なる処理の軽減を図ることができる。なお、S300~S320がS100~S120、S330~S340がS150~S160、S360~S370がS130~S140、S380がS180とそれぞれ全く同様の処理を行っている。

【0061】ところで、ある回数以上処理を繰り返せば、判定パラメータの偏差が許容範囲内に納まることが予めわかっていれば、判定パラメータの偏差を実際に算出することなく、繰返回数を収束条件とすることができる。この場合、図8に示すように、ゲート遅延時間Tg,全消費電力Ph,全遅延時間Thを算出するステップ(S450~S470)を、処理の繰り返しループの外に出すことができると共に、収束判定にて否定判定さ 50

れた(S420-NO)場合のみ、次回の処理に用いる発熱量パラメータTHpの算出(S430, S440)を行えばよいため、より一層、処理量を軽減することができる。なお、 $S400\sim S410$ が $S100\sim S110$ ,  $S430\sim S440$ が $S150\sim S160$ ,  $S450\sim S470$ が $S120\sim S140$ , S480がS180とそれぞれ全く同様の処理を行っている。

【0062】なお、上記実施例では、ゲート消費電力PG及びゲート遅延時間Tgの算出(S110とS120, S210とS220, S310とS320)を、別々に順次実行するようにされているが、これらの処理は同時に実行してもよい。また、同様に、全消費電力Ph及び全遅延時間Thの算出(S130とS140, S360とS370, S460とS470)も、同時に実行してもよい。

[第2実施例] 次に、本発明の第2実施例について説明 する。

【0063】実際の論理回路の各ゲート間を結ぶ配線には少なからず配線容量があり、そのため上記第1実施例で示したゲートのゲート遅延時間Tg等は、その影響を受ける。そこで、本第2実施例では、配線容量の影響を考慮した論理シュミレーションを行っている。

【0064】ここで、図9は、本第2実施例の論理シュミレーション装置2を表すブロック図、図10は、各配線の配線容量の内容を表す説明図である。本実施例の論理シュミレーション装置2は、第1実施例と異なるのは、配線容量を考慮して、前述した駆動能力R、ゲート遅延時間Tg及び単位ゲート消費電力Pg等を算出している点であるので、以下の説明では、第1実施例と異なる点についてのみ説明する。

【0065】まず、論理シュミレーション装置2の全体 構成では、図9に示すように、データ記憶部10に、各 配線の配線容量LCを各配線に対応させて記憶した配線 情報αが記憶されている点が第1実施例と異なる。この 配線情報αは、入力操作部12から入力され、具体的に は、例えばシュミレーションを行う論理回路が、図10 (a) に示すような、2つのNOT回路g1, g2と、 NAND回路g3とからなり、NOT回路g1, g2の 出力側がNAND回路g3の入力側にそれぞれ接続され た論理回路であるとすると、図10(b)に示すよう に、NOT回路g1の入力側に接続される配線n1、N OT回路g1の出力側及びNAND回路g3の入力側に 接続される配線n3、NOT回路g2の入力側に接続さ れる配線n2、NOT回路g2の出力側及びNAND回 路g3の入力側に接続される配線n4、NAND回路g 3の出力側に接続される配線n5のそれぞれ(領域M 3) について対応付けられた配線容量LCに関するデー タ(領域M4)である。

【0066】次に、本実施例では、駆動能力R、ゲート 遅延時間Tg及び単位ゲート消費電力Pgが、前述した

自己発熱量THの他に、この配線容量LCをパラメータとする関数fr(TH,LC)、fp(TH、LC)、ft(TH,LC)としてライブラリLBに定義される点が第1実施例と異なる。ところで、通常、配線容量LCとゲート遅延時間Tg及び単位ゲート消費電力Pgとの関係は、論理回路の動作をシュミレーションするにあたりよく知られたものなので、本実施例ではその説明を省略する。尚、この関係については、予め実験等から分かったものを利用してもよいことはもちろんである。

【0067】そして本実施例では、上述した関数(fp(TH,LC)等)で定義されたゲート遅延時間Tg等に基づいて、図4に示すフローチャートにおける、ゲート消費電力PWを算出する処理S110以下を実行しているのである。以上のような構成を有する本実施例の論理シュミレーション装置2を実行すると、第1実施例の効果に加え、配線容量LCを考慮したゲート消費電力PGや、全消費電力Ph、全遅延時間Thを求めることができるので、第1実施例の論理シュミレーション装置2に比べ、実際に即したより正確なシュミレーションを行うことができる。

【0068】なお、配線情報  $\alpha$  は、実際の論理回路から 算出したものを用いてもよいし、仮想的な配線容量を用 いてもよい。また、配線情報  $\alpha$  は、入力操作部 12 によ り入力されるものに限られず、フロッピーディスク等の 外部装置からRAM 16 c にロードするようにしてもよ く、どのように入力してもよい。

[第3実施例] 次に、本発明の第3実施例について説明 する。

【0069】ここで、図11は、本実施例の論理シュミレーション装置の概略構成を表すブロック図、図12は、各配線毎の論理の遷移回数を説明するための説明図、図13は、本実施例の論理シュミレーション装置2が実行するシュミレーション処理を表すフローチャートである。

【0070】以下の説明では、第1実施例と異なる点についてのみ説明する。尚、以下の説明において遷移とは論理信号の信号レベルが0から1、あるいは1から0に変化すること、遷移回数とは、信号レベルが変化した回数を言う。まず、本実施例のシュミレーション装置2は、図11に示すように、第1実施例においてテストベクターVCに変わって、上述した状態遷移情報 $\beta$ がデータ記憶部10に記憶されてい点が異なる。この状態遷移情報 $\beta$ は、第2実施例で例示した図10(a)に示す論理回路を用いて具体的な例について説明すると、図12に示すように、各配線 $\alpha$ 1~ $\alpha$ 15年に対応して(領域M5)、各配線毎の遷移回数(領域M6)を規定したものである。

【0071】また、第1実施例では、S110のステップを実行する場合、ゲートに接続される各配線について、論理の遷移回数を算出した上で、テストベクタVC 50

の全期間に渡る消費電力を算出していたのに対して、本 実施例の論理シュミレーション装置2では、S510に おいて、予め入力された各配線によって伝達される論理 信号の遷移回数に、fp(TH)で定義された単位ゲー ト消費電力Pgを乗じることによって、ゲート消費電力 PWを算出している点が異なる。具体的には、例えば図 10(a)のゲートg2について見ると、入力側の配線 n2の遷移が160回、出力側のn4の遷移が160回 なので、合計320回の遷移に対しゲート消費電力PW = 320fp(TH)という計算を行っているのであ る。

【0072】そのため、本実施例の論理シュミレーション装置2では、テストベクタVCを用いて個々のゲートの動作を再現することなく、ゲート消費電力PWを算出することができるので、処理速度が格段に早くなる。尚、本実施例の論理シュミレーション装置2では、図13に示すように、図6に示したS120及びS140にあたる処理を行っていない点が第1実施例と異なる。このうち、S120にあたる処理を行っていない点が第1実施例と異なる。こ120で算出されるゲート遅延時間Tgが全遅延時間Dhを算出するためだけに用いられ、全消費電力Phを算出するために利用されないからである。また、S140にあたる処理を行っていないのは、そのためだけにテストベクタVCを用いて個々のゲートの動作を再現する必要が生じ、状態遷移情報 $\beta$ を用いることによって上昇した処理スピードが抑制されてしまうからである。

【0073】ただし、個々のゲートのゲート遅延時間Tgは、テストベクタVCを用いて個々のゲートの動作を再現する必要がないので、必要に応じてS120に該当する処理を行って、ゲート遅延時間Tgを算出してもよい。また尚、図13の処理において、S500はS10に、S510はS110に、S520はS120に、S530はS130に、S550はS150に、S560はS160に、S570はS170に、S580はS180にそれぞれ対応する。

【0074】以上説明した本実施例の論理シュミレーション装置2を用いると、全遅延時間Dhの算出を行わず、しかも、テストベクタVCを用いて個々のゲートの動作を再現することなくゲート消費電力PWを算出することができるので、論理回路の動作限界を知るためのパラメータである全消費電力Phを簡易的に短時間で求めることができる。

【0075】そのため、本実施例の論理シュミレーション装置2を用いれば、論理回路の設計において、その初期のアイディア段階において動作限界を越える論理回路が分かるため排除され、そのため設計の最終段階に至って初めて論理回路が動作しないことが分かるといったことが少なくなるので、論理回路の設計を効率よく進めることができる。

【0076】ただし、本実施例の論理シュミレーション

装置2では、正確な遷移回数を入力すれば精密に全消費電力Phを算出できるので、アイディア段階ばかりでなく設計のどの段階でも用いることができることはもちろんである。また、本実施例の論理シュミレーション装置2を用いると、テストベクタVCを準備できない、例えば、簡易的に論理回路で消費する全消費電力Phを求めたい用途において適当な遷移回数を記憶したファイルを準備しさえすれば、全消費電力Phを算出することができる。

【0077】尚、本実施例の論理シュミレーション装置 102は、S510においてゲート消費電力Pgを算出するのに、ライブラリLB、ネットリストNL及び状態遷移情報βを用いていたが、第2実施例と同様、各ゲートを接続する各配線の配線容量を用いて論理シュミレーションを実行するようにしてもよい。

#### 【図面の簡単な説明】

【図1】 第1実施例の論理シミュレーション装置の概略構成を表すブロック図である。

【図2】 第1実施例においてライブラリの内容を表す 説明図である。

【図3】 第1実施例において単位ゲート消費電力、及びゲート遅延と自己発熱の発熱量との関係を表すグラフである。

【図4】 第1実施例においてシミュレーション処理の 内容を表すフローチャートである。

【図5】 第1実施例においてシミュレーション処理を

実行した場合の全消費電力,全遅延時間等の算出過程を 表す説明図である。

【図6】 第1実施例においてシミュレーション処理の 変形例を表すフローチャートである。

【図7】 第1実施例においてシミュレーション処理の 変形例を表すフローチャートである。

【図8】 第1実施例においてシミュレーション処理の 変形例を表すフローチャートである。

【図9】 第2実施例の論理シュミレーション装置の概略構成を表すブロック図である。

【図10】各配線毎の論理の遷移回数を表す説明図であ ス

【図11】第3実施例の論理シュミレーション装置の概略構成を表すブロック図である。

【図12】各配線の配線容量を表す説明図である。

【図13】第3実施例の論理シュミレーション装置で実 行する論理シュミレーションのフローチャートである。

#### 【符号の説明】

2…論理シミュレーション装置 10…データ記憶部 12…入力操作部 14…表示部 16…シミュレ ーション実行部

Dh…全遅延時間 LB…ライブラリ NL…ネットリスト

 $VC\cdots$ テストベクター、 $\alpha$   $\cdots$ 配線情報、 $\beta$   $\cdots$ 状態遷移情報



20





【図11】





【図12】



【図13】

